<template>
  <div class="user-info">
    <!-- 个人信息 -->
    <el-form label-width="220px">
      <!-- 工号 入职时间 -->
      <el-row class="inline-info">
        <el-col :span="12">
          <el-form-item label="工号">
            <el-input v-model="userInfo.workNumber" class="inputW" />
          </el-form-item>
        </el-col>

        <el-col :span="12">
          <el-form-item label="入职时间">
            <el-date-picker
              ref="dateRef"
              v-model="userInfo.timeOfEntry"
              style="width: 300px"
              type="date"
              class="inputW"
              @change="dateChangeFn"
            />
          </el-form-item>
        </el-col>
      </el-row>
      <!-- 姓名 部门 -->
      <el-row class="inline-info">
        <el-col :span="12">
          <el-form-item label="姓名">
            <el-input v-model="userInfo.username" class="inputW" />
          </el-form-item>
        </el-col>
        <el-col :span="12">
          <el-form-item label="部门">
            <el-input v-model="userInfo.departmentName" class="inputW" />
          </el-form-item>
        </el-col>
      </el-row>
      <!--手机 聘用形式  -->
      <el-row class="inline-info">
        <el-col :span="12">
          <el-form-item label="手机">
            <el-input v-model="userInfo.mobile" style="width: 300px" />
          </el-form-item>
        </el-col>
        <el-col :span="12">
          <el-form-item label="聘用形式">
            <el-select v-model="userInfo.formOfEmployment" class="inputW">
              <el-option v-for="item in EmployeeEnum.hireType" :key="item.id" :label="item.value" :value="item.id" />
            </el-select>
          </el-form-item>
        </el-col>
      </el-row>
      <!-- 员工照片 -->
      <el-row class="inline-info">
        <el-col :span="12">
          <el-form-item label="员工头像">
            <!-- 放置上传图片 -->
            <UploadImg :img-url.sync="userInfo.staffPhoto" />
          </el-form-item>
        </el-col>
      </el-row>
      <!-- 保存个人信息 -->
      <el-row class="inline-info" type="flex" justify="center">
        <el-col :span="12">
          <el-button type="primary" @click="saveUser">保存更新</el-button>
          <el-button @click="$router.back()">返回</el-button>
        </el-col>
      </el-row>
    </el-form>
  </div>
</template>

<script>
import { getUserDetailByIdAPI } from '@/api/user'
import { saveUserDetailByIdAPI } from '@/api/employees'
import EmployeeEnum from '@/api/constant/employees'
import { parseTime } from '@/utils'

export default {
  data() {
    return {
      userId: this.$route.query.id,
      EmployeeEnum, // 员工枚举数据
      userInfo: {}
    }
  },
  created() {
    // 调用获取用户信息的 API
    this.loadUserInfoById()
  },
  methods: {
    // 获取用户信息
    async loadUserInfoById() {
      const res = await getUserDetailByIdAPI(this.userId).catch(err => err)
      // console.log(res)
      if (!res.success) return this.$message.error(res.message)
      this.userInfo = res.data
      this.userInfo.timeOfEntry = new Date(res.data.timeOfEntry)
    },
    // 保存用户信息的更改
    async saveUser() {
      // 时间对象转成字符串
      // this.userInfo.timeOfEntry = parseTime(this.$refs.dateRef.value).split(' ')[0]
      if (this.userInfo.timeOfEntry instanceof Date) {
        // 时间对象转成字符串
        this.userInfo.timeOfEntry = parseTime(this.userInfo.timeOfEntry).split(' ')[0]
      }
      const res = await saveUserDetailByIdAPI(this.userInfo)
      if (!res.success) return this.$message.error(res.message)
      this.loadUserInfoById()
      this.$message.success(res.message)
    },
    // 日期改变--格式转换
    dateChangeFn(date) {
      // 时间对象转成字符串
      this.userInfo.timeOfEntry = parseTime(date).split(' ')[0]
    }
  }
}
</script>

<style scoped lang="scss">
.user-info {
  padding-top: 20px;
}
</style>
